# EXPERIMENT NO 02

## AIM

To study of Half and Full adder.

## THEORY

Digital computers perform a variety of information-processing tasks. Among the basic functions encountered are various arithmetic operations. The most basic arithmetic operations are, no doubt, the addition and subtraction of binary digits (bit).

## HALF ADDER

The possible operations, when we want to add only two bits, would be the

followings:

0 + 0 = 0 0 + 1 = 1

1 + 0 = 1

1 + 1 = 0 & Carry 1

Above mentioned operation could be performed by a **Half Adder** circuit.

## Truth Table 1: HALF ADDER

We arbitrarily assign symbols **A** and **B** to the two inputs and **S** (for sum) and **Cout** (for Carry) to the two outputs. Truth table for Half Adder as shown below:-

Table 1: Truth Table for Half Adder operation

|  |  |  |  |
| --- | --- | --- | --- |
| **Input** | | **Output** | |
| **A** | **B** | **S** | **Cout** |
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |

The simplified Boolean function for the two outputs can be written from this truth table as:-

## S = A'.B +A.B'

**Cout = A.B**

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAANQAAABlCAIAAAC6KlqfAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAADi0lEQVR4nO2d23KEIBAFIbX//8vkwRRLvK2LA4fB7setRAHbYRDEmFIKBTHGEMLqR7hCjLFst6Ulj6CFQwgvdQFm5sSwlZrPdPHwZpU3h8cYvA1+F8vvsbL3GVS+cUryLdX+haLWvqpczbvbLW++GONXrQYm5AZ/SCBsnvOd5919jtCZ8r5NKVXcxjkEhKkVjEf1lNdcXoBq7vS8u0cLPtvhIz/qApwxZYt/S0ppCZ/qgtjzCkW/tq0hmd8g1HXfg/PO+bYVm/Ju68BKFCtvcvzrr+DWBJMy/JzUp0wHYQQkXXA2JBOMrBg654Ndevq3G5us/Hudx8/JkoxpkKeANt3u/UOAhD7xr2nqxcICx/SJf8tZWqyEGHf07v3Jgu2j5vMTGR7tSiGtBt1EPt9IbtEcC2+empyvCX3CnvfOAfm80se8bbZnCPK5pFvM2x3tkvM9l869bbvRLvJ5QjW32+iMyPePkRfPeR9ebCHne3OytOzb45gPdeczLxD5xmfkYHyTHvJVBxLhaq4RFpJNrN3Cn3y7bW1V7brjSDoak+tt9c7UxNot/It8q0xlyjzjI/fN473dixx2u1bzd4+izrynOZdhwKHB75YMhhzK95C0w5DdXaqO8j8aNqzkY+ukO+y+6AAnMOAAGYczHLw3Ca1heg1kIB/IOJSP0S60htEuyPiTD8+gP+R8IAP5QAbygQzkAxnIBzKQD2QgH8hAPpCBfCAD+UAG8oEM5AMZyAcykA9kIB/IQD6QgXwgA/lABvKBDOQDGcgHMpAPZCAfyEA+kIF8IAP5QAbygQzkAxnIBzKQD2QgH8jgIzANsdpOfdbdE5GvLSbezLpFMfI5oPwsxUwKkvO5IaW0fI1RXRAzkG/N4Fd3Jv/odncY/Oou/k3Q/yLfP2yvaDuJ5/CPbtcrE/S/yOcY7/4hH8hAPt+4Dn7IBzKQzz1+gx+PWuASLb5IinzwgaxdFi7GaDLRjHyTcKfnveJQ+TdWHT3yTUKj2Y6jCLf4d3OWBfmgkvu6M9oFGcgHMpDPPX6XtyAfVJIfuFT/I/L5pnXYK18fWZ038JwP+lBafhTwyt+3Lz2tfI0xIp9j+mR7WZ2tW6vCrP74vGwppaHlczpf3ofO44wW5xpXPqcjuJJ2N4/fEW4JAw5/eDRv9z70Vw1HmFsy+KYFu0nh7lqs5Ufka4ihfINrV8e4Od8csFHVCb8xvSYC0UWE7gAAAABJRU5ErkJggg==)The circuit diagram for the Half Adder to implement above mentioned Boolean function could be quite a few. We will however verify only one.

Figure 1: Half Adder using AND and XOR gates.

## FULL ADDER

We know that in practice, all addition operations must take into account the Carry bit (or digit) from the previous operation. Adders in digital computers also take into account the Carry bit from last operation and add it with the Augend and Addend bits of the present operation to complete the addition operation. The possible operations are:

0 + 0 + 0 (carry) = 0

0 + 0 + 1 (carry) = 1 0 + 1 + 0 (carry) = 1

0 + 1 + 1 (carry) = 0 & carry 1 (to be added to next higher digit)

1 + 1 + 0 (carry) = 0 & carry 1 (to be added to next higher digit) 1 + 1 + 1 (carry) = 1 & carry 1 (to be added to next higher digit)

The adder that performs the addition of three bits (two significant bits and a previous carry) is called a **Full Adder**.

As mentioned in the beginning, a full-adder is a combinational circuit that forms the arithmetic sum of three input bits (two significant bits and a previous carry bit) and two output bits. We arbitrarily assign symbols **A** and **B** to the two significant bit inputs and **Cin** for the Carry from the previous lower significant position, and **S** (for sum) and **Cout** (for Carry) to the two outputs.

Truth table for the Full Adder is shown below:

|  |  |  |  |  |
| --- | --- | --- | --- | --- |
| **Input** | | | **Output** | |
| **A** | **B** | **Cin** | **S** | **Cout** |
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 |
| 0 | 1 | 1 | 0 | 1 |
| 1 | 0 | 0 | 1 | 0 |
| 1 | 0 | 1 | 0 | 1 |
| 1 | 1 | 0 | 0 | 1 |
| 1 | 1 | 1 | 1 | 1 |

Simplified Boolean function for the two outputs can be written from this truth table as:-

**S = A ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAAAOCAIAAACQKrqGAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAAT0lEQVQokbVRRw4AIAij/v/P9UAwLBNNtLdCoQyQFAMAiQhZJVXUFPi6RUnW+NjZVYqaANAuELo+w58BbqTet5nPgvmuSZ3p+WP7ZZNIMQHPsz74tOZ0HAAAAABJRU5ErkJggg==)** **B ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAAAOCAIAAACQKrqGAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAAT0lEQVQokbVRRw4AIAij/v/P9UAwLBNNtLdCoQyQFAMAiQhZJVXUFPi6RUnW+NjZVYqaANAuELo+w58BbqTet5nPgvmuSZ3p+WP7ZZNIMQHPsz74tOZ0HAAAAABJRU5ErkJggg==)** **Bin CC Cout = (A ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAA4AAAAOCAIAAACQKrqGAAAABmJLR0QA/wD/AP+gvaeTAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAAT0lEQVQokbVRRw4AIAij/v/P9UAwLBNNtLdCoQyQFAMAiQhZJVXUFPi6RUnW+NjZVYqaANAuELo+w58BbqTet5nPgvmuSZ3p+WP7ZZNIMQHPsz74tOZ0HAAAAABJRU5ErkJggg==)** **B) C +A.B**

The circuit diagram for the Full Adder is as under:

![](data:image/png;base64,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)

Figure 2: Full Adder comprising of two Half Adders and an OR gate